## Claims

2

3

4

5

6

1

2

3

4

5

1

2

| 1 | 1. | A floating point accumulator, said accum | ulator comprising |
|---|----|------------------------------------------|-------------------|
|---|----|------------------------------------------|-------------------|

A first circuit network which is designed to convert floating point numbers expressed in base

2 format into floating point numbers expressed in a new base format represented by a whole number;

A second circuit network which is designed to compare the exponents of two of the converted numbers by comparing some number of most significant bits of the exponents of the two converted numbers, said bits representing exponent values of the two converted numbers;

A third circuit network which is designed to shift mantissas, add shifted mantissas of the two converted numbers using compressors, choose an accurate result mantissa, and partially normalize feedback mantissas;

A fourth circuit network designed to convert back to base 2 format both the mantissa and exponent of the final result.

2. The floating point accumulator of claim 1, wherein said floating point numbers are converted into numbers expressed in a new base by shifting the mantissas of each floating point number by a quantity equal to the K least significant bits of the exponents of the floating point numbers and by removing the K least significant bits from the exponents, where K equals the logarithm to the base 2 of the new base.

3. The floating point accumulator of claim 2, wherein said accumulator includes at least two registers, including an exponent register storing a first exponent value and a feedback exponent

SJ01 24981 v 1 -12-

Ħ

2

1

2

3

4

1

- register that initially stores a second exponent value and that is updated periodically with a feedback 1 exponent value.
- The floating point accumulator of claim 3, wherein a comparator compares the exponent 4. values each stored in one of the exponent registers and transmits a control signal indicating the larger 2 3 of the two exponent values.
  - The floating point accumulator of claim 4, wherein a first multiplexer receives said control 5. signal and said exponent values and transmits the larger of the exponent values.
  - The floating point accumulator of claim 5, wherein a plurality of adding devices receive said 6. exponent values, calculate a plurality of augmented values each equal to the sum of one of the values and one and transmit the augmented values.
  - The floating point accumulator of claim 6, wherein a second multiplexer receives said 7. augmented values and said control signal and transmits the larger of the augmented values.
  - The floating point accumulator of claim 7, wherein a third multiplexer receives the 8. augmented value transmitted by the second multiplexer, the value transmitted by the first multiplexer, and an control signal which selects either the value transmitted by the first multiplexer or augmented value transmitted by second multiplexer.
    - The floating point accumulator of claim 8, wherein a fourth multiplexer receives said 9.

-13-SJ01 24981 v 1

smaller value it receives.

exponent values, another of said exponent values reduced the whole number amount by a subtracting device, and an overflow control signal which causes the greater of the values received by the fourth multiplexer to be transmitted if a sum of the shifted mantissas of the floating point numbers exceeds the mantissa size supported by said accumulator, otherwise the fourth multiplexer transmits the

10. The floating point accumulator of claim 9, wherein a fifth multiplexer receives the value transmitted by the fourth multiplexer, the value transmitted by the third multiplexer, and a control signal, and selects the value transmitted by the fourth multiplexer if the feedback exponent value is greater than first exponent value by one or two and there are more than 31 leading zeros or ones in the feedback mantissa, otherwise the fifth multiplexer transmits the value received from the third multiplexer.

- 11. The floating point accumulator of claim 10, wherein a sixth multiplexer receives the value transmitted by the fifth multiplexer, the first exponent value, and a control signal that causes the first exponent value to be transmitted from the sixth multiplexer if all bits of a feedback mantissa are zero, otherwise the sixth multiplexer transmits the value transmitted by the fifth multiplexer.
- 12. The floating point accumulator of claim 11, wherein the values transmitted from the sixth multiplexer are transmitted to the feedback exponent register in a feedback loop and replace the value previously stored in the feedback exponent register during the last execution of the second circuit network.

SJ01 24981 v 1 -14-

5

6

1

3

4

2

2

3

1 13. The floating point accumulator of claim 12, wherein a first mantissa is received by and stored

in a mantissa register and a second mantissa is received by and stored in a feedback mantissa register

, ,

that are components of said third circuit network.

1 14. The floating point accumulator of claim 13, wherein the first mantissa is transmitted to a first

shifter and is shifted right by a number of bits equal to the base of the numbering system in which

the mantissas are added if the feedback exponent is greater than the first exponent.

15. The floating point accumulator of claim 14, wherein the second mantissa is transmitted to

a second shifter and is shifted right by a number of bits equal to the base of the numbering system

in which the mantissas are added if the first exponent is greater than the feedback exponent.

16. The floating point accumulator of claim 15, wherein said first mantissa is transmitted to a

third shifter and said second mantissa is transmitted to a fourth shifter and said first mantissa is

shifted right by the third shifter by a number of bits equal to the base of the numbering system in

which the mantissas are added if the first exponent is less than the feedback exponent by two, and

said second mantissa is shifted left by a number of bits equal to the base of the numbering system

in which the mantissas are added.

17. The floating point accumulator of claim 16, wherein said first and second mantissas are

2 added by a first adding device in the mantissa loop forming a mantissa sum that is shifted right by

a number of bits equal to the base of the numbering system in which the mantissas are added if the

mantissa sum contains more significant bits than are supported by the accumulator.

SJ01 24981 v 1 -15-

1

3

4

2

2

3

4

5

selecting multiplexer if the first and second exponents differ by one or if the exponents are equal,

The floating point accumulator of claim 17, wherein the mantissa sum is transmitted by a

and otherwise the mantissa associated with the larger exponent is transmitted by the selecting

multiplexer.

18.

1 19. The floating point accumulator of claim 18, wherein a leading zero anticipator generates a

signal that indicates whether the number of leading zeroes or ones contained in the second mantissa

is equal or greater than the base of the numbering system in which accumulation is performed and

is a portion of the control signal used to control said fifth multiplexer in the second circuit network.

20. The floating point accumulator of claim 19, wherein a second adder in said third circuit adds

the shifted values generated by the third and fourth shifters and transmits the calculated sum to a

sixth shifter that shifts the sum to the right by the base of the number system in which mantissas are

added if a mantissa overflow condition occurs when the mantissa sum is calculated.

1 21. The floating point accumulator of claim 20, wherein a third multiplexer in the mantissa loop

receives the bit stream transmitted by the sixth shifter and the bit stream transmitted by second

multiplexer in the mantissa loop and transmits the bit stream received from the sixth shifter if the

feedback exponent value is greater than first exponent value by one or two and the number of leading

zeroes or ones in the feedback manitssa is equal or greater than the base of the numbering system

6 in which accumulation is performed.

SJ01 24981 v 1 -16-

| T. |
|----|
| Ū  |
|    |
| T. |
| 2  |
| Fi |
| 3  |
| #  |
| 4  |
|    |
| 1  |
| 6  |

8

9

10

11

12

1

1

2

3

4

| 1 | 22.    | The floating point accumulator of claim 21, wherein the base of the number system in which         |
|---|--------|----------------------------------------------------------------------------------------------------|
| 2 | the ma | antissas and exponents of the floating point numbers are added is at least 32 for single precision |
| 3 | forma  | t and at least 64 for double precision format.                                                     |

1 4) T

23. The floating point accumulator of claim 22, further comprises a post normalization circuit wherein components of a mantissa result are added, shifted to remove leading zeroes, and shifted to convert the mantissas back into a number expressed in base 2 format, and the exponent result is increased or decreased by an amount that converts it back to base 2 format.

## 24. A method of adding floating point numbers, said method comprising:

Converting the floating point numbers expressed in base 2 format into floating point numbers expressed in a second base format represented by a whole number;

Comparing the exponents of two of the floating point numbers by comparing some number of the most significant bits of the exponents of the two floating point numbers, said bits representing exponent values of the two converted floating point numbers and choosing a correct result exponent;

Shifting and adding mantissas of two of the floating point numbers using one or more compressors and choosing a correct result mantissa;

Repeating said comparing, shifting and adding multiple times using two of the floating point numbers, wherein one of the floating point numbers consists of a result exponent and result mantissa previously determined;

Converting the result mantissa and exponent back to base 2 format.

## 25. The method of claim 24 further comprises storing an exponent value of a first floating point

SJ01 24981 v 1 -17-

1

2

3

4

4

1

2

3

4

5

number in an exponent register and an exponent values of a second floating point number in an

4 41 1

exponent feedback register that is updated periodically with a feedback exponent value produced by

3 said comparison of exponent.

1 26. The method of claim 25, wherein a first mantissa is received by and stored in a mantissa

register and a second mantissa is received by and stored in a feedback mantissa register that is

updated periodically with a feedback mantissa value produced by said shifting and adding of

mantissas.

27. The method claim 26 further comprises a zero detector that detects whether all bits of the

feedback mantissa stored in the feedback mantissa register are zero.

28. The method of claim 27 further comprises a post normalization circuit wherein components

of a mantissa result are added, shifted to remove leading zeroes, and shifted to convert the mantissas

back into numbers expressed in base 2 format, and the exponent result is increased or decreased by

an amount that converts it back to base 2 format.

29. A floating point accumulator, wherein the first mantissa is received by and stored in a

mantissa register and a second mantissa is received by and stored in a feedback mantissa register in

a mantissa circuit loop that is designed to partially normalize feedback mantissas, and a first

exponent is stored in an exponent register and a second exponent is stored in a feedback exponent

register in an exponent circuit loop.

SJ01 24981 v 1 -18-

- 1 30. The accumulator of claim 29, wherein constant shifters are used to shift mantissas in the
- 2 mantissa circuit loop, compressors are used to add mantissas in the mantissa circuit loop, and
- 3 comparators are used to compare exponents in the exponent loop.

SJ01 24981 v 1 -19-